
//给定一个整数数组 asteroids，表示在同一行的小行星。 
//
// 对于数组中的每一个元素，其绝对值表示小行星的大小，正负表示小行星的移动方向（正表示向右移动，负表示向左移动）。每一颗小行星以相同的速度移动。 
//
// 找出碰撞后剩下的所有小行星。碰撞规则：两个行星相互碰撞，较小的行星会爆炸。如果两颗行星大小相同，则两颗行星都会爆炸。两颗移动方向相同的行星，永远不会发生碰
//撞。 
//
// 
//
// 示例 1： 
//
// 
//输入：asteroids = [5,10,-5]
//输出：[5,10]
//解释：10 和 -5 碰撞后只剩下 10 。 5 和 10 永远不会发生碰撞。 
//
// 示例 2： 
//
// 
//输入：asteroids = [8,-8]
//输出：[]
//解释：8 和 -8 碰撞后，两者都发生爆炸。 
//
// 示例 3： 
//
// 
//输入：asteroids = [10,2,-5]
//输出：[10]
//解释：2 和 -5 发生碰撞后剩下 -5 。10 和 -5 发生碰撞后剩下 10 。 
//
// 示例 4： 
//
// 
//输入：asteroids = [-2,-1,1,2]
//输出：[-2,-1,1,2]
//解释：-2 和 -1 向左移动，而 1 和 2 向右移动。 由于移动方向相同的行星不会发生碰撞，所以最终没有行星发生碰撞。 
//
// 
//
// 提示： 
//
// 
// 2 <= asteroids.length <= 104 
// -1000 <= asteroids[i] <= 1000 
// asteroids[i] != 0 
// 
//
// 
//
// 注意：本题与主站 735 题相同： https://leetcode-cn.com/problems/asteroid-collision/ 
// Related Topics 栈 数组 
// 👍 0 👎 0

package leetcode.editor.cn;
/**
  * 题目Id：剑指 Offer II 037
  * 题目：小行星碰撞
  * 日期：2021-08-26 18:39:19
*/
public class XagZNi {
    public static void main(String[] args) {
        Solution solution = new XagZNi().new Solution();
    }
    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public int[] asteroidCollision(int[] asteroids) {

        int [] nums= new int [asteroids.length];

        int preIndex=0;




        for (int i=1;i<asteroids.length;i++){
            //如果后续小于0  向前碰撞
            if (asteroids[i]<0){
                for (int j=i;j>1;j--){
                       if (asteroids[j-1]<0){
                           continue;
                       }else {
                           if (Math.abs(asteroids[j])>asteroids[j-1]){}
                       }

                }

            }
        }
        return asteroids;
    }


    public boolean left(int [] nums,int index){
            if (index+1<nums.length){
                if (nums[index]>0){
                    left(nums,index++);
                }else {
                    right(nums,index);
                    left(nums,index++);
                }
            }
            return true;
    }
    public boolean right(int [] nums,int index){
            if (index-1>=0){
                //碰撞
               if(nums[index-1]>0){
                   if (Math.abs(nums[index])>nums[index-1]){
                       nums[index-1]=nums[index];
                       nums[index]=Integer.MIN_VALUE;
                       right(nums,index--);
                   }else {

                   }

               }


            }
            return true;
     }

}
//leetcode submit region end(Prohibit modification and deletion)

}    
